using Umbraco.Cms.Core.Configuration;

namespace Umbraco.Cms.Infrastructure.ModelsBuilder.Building;

/// <summary>
///     Represents a model property.
/// </summary>
public class PropertyModel
{
    /// <summary>
    ///     Gets the alias of the property.
    /// </summary>
    public string Alias = string.Empty;

    /// <summary>
    ///     Gets the clr name of the property.
    /// </summary>
    /// <remarks>This is just the local name eg "Price".</remarks>
    public string ClrName = string.Empty;

    /// <summary>
    ///     Gets the CLR type name of the property values.
    /// </summary>
    public string ClrTypeName = string.Empty;

    /// <summary>
    ///     Gets the description of the property.
    /// </summary>
    public string? Description;

    /// <summary>
    ///     Gets the generation errors for the property.
    /// </summary>
    /// <remarks>
    ///     This should be null, unless something prevents the property from being
    ///     generated, and then the value should explain what. This can be used to generate
    ///     commented out code eg in InMemoryAuto mode.
    /// </remarks>
    public List<string>? Errors;

    /// <summary>
    ///     Gets the Model Clr type of the property values.
    /// </summary>
    /// <remarks>
    ///     As indicated by the <c>PublishedPropertyType</c>, ie by the <c>IPropertyValueConverter</c>
    ///     if any, else <c>object</c>. May include some ModelType that will need to be mapped.
    /// </remarks>
    public Type ModelClrType = null!;

    /// <summary>
    ///     Gets the name of the property.
    /// </summary>
    public string Name = string.Empty;

    /// <summary>
    ///     Adds an error.
    /// </summary>
    public void AddError(string error)
    {
        if (Errors == null)
        {
            Errors = new List<string>();
        }

        Errors.Add(error);
    }
}
